package com.powernode.service.impl;

import cn.hutool.core.collection.CollectionUtil;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.powernode.domain.SysUser;
import com.powernode.domain.SysUserRole;
import com.powernode.mapper.SysUserMapper;
import com.powernode.mapper.SysUserRoleMapper;
import com.powernode.service.SysUserRoleService;
import com.powernode.service.SysUserService;
import com.powernode.util.AuthUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import org.springframework.util.StringUtils;

import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import java.util.stream.Collectors;

@Service
public class SysUserServiceImpl extends ServiceImpl<SysUserMapper, SysUser> implements SysUserService{

    @Autowired
    private SysUserMapper sysUserMapper;

    @Autowired
    private SysUserRoleMapper sysUserRoleMapper;

    @Autowired
    private SysUserRoleService sysUserRoleService;

    @Autowired
    private BCryptPasswordEncoder passwordEncoder;

    /**
     * 新增管理员有两步
     *  1.新增管理员
     *  2.新增管理员与角色的关系
     *
     * @param sysUser
     * @return
     */
    @Override
    @Transactional(rollbackFor = Exception.class)
    public Integer saveSysUser(SysUser sysUser) {
        // 新增管理员
        sysUser.setCreateUserId(AuthUtils.getLoginUserId());//管理员的创建者
        sysUser.setCreateTime(new Date());                  //创建时间
        sysUser.setShopId(1L);                              //店铺ID
        sysUser.setPassword(passwordEncoder.encode(sysUser.getPassword()));
        int i = sysUserMapper.insert(sysUser);              //新增成功后获取返回值，用于建设关系
        System.out.println("i======================================"+i);
        if (i > 0) {
            // 获取管理员标识
            Long userId = sysUser.getUserId();
            // 新增管理员与角色的关系
            // 获取管理员的角色id集合
            List<Long> roleIdList = sysUser.getRoleIdList();
            // 判断是否有值
            if (CollectionUtil.isNotEmpty(roleIdList) && roleIdList.size() != 0) {
                // 创建管理员与角色关系的集合
                List<SysUserRole> sysUserRoleList = new ArrayList<>();
                // 循环遍历角色id集合
                roleIdList.forEach(roleId -> {
                    // 创建管理员与角色的关系
                    SysUserRole sysUserRole = new SysUserRole();
                    sysUserRole.setUserId(userId);
                    sysUserRole.setRoleId(roleId);
                    /*// 新增管理员与角色的关系
                    注意：不建议在循环中操作数据库，大家尽量需要避免在循环中操作数据库
                    sysUserRoleMapper.insert(sysUserRole);*/
                    sysUserRoleList.add(sysUserRole);
                });
                // 批量添加管理员与角色的关系
                sysUserRoleService.saveBatch(sysUserRoleList);
            }
        }
        return i;
    }

    @Override
    public SysUser querySysUserInfoByUserId(Long id) {
        // 根据标识查询管理员信息
        SysUser sysUser = sysUserMapper.selectById(id);
        // 根据用户标识查询管理员与角色的关系集合
        List<SysUserRole> sysUserRoleList = sysUserRoleMapper.selectList(new LambdaQueryWrapper<SysUserRole>()
                .eq(SysUserRole::getUserId, id)
        );
        // 判断是否有值
        if (CollectionUtil.isNotEmpty(sysUserRoleList) && sysUserRoleList.size() != 0) {
            // 从管理员与角色关系集合中获取角色id集合
            List<Long> roldIdList = sysUserRoleList.stream().map(SysUserRole::getRoleId).collect(Collectors.toList());
            sysUser.setRoleIdList(roldIdList);
        }
        return sysUser;
    }

    /**
     * 修改管理员信息
     *  1.删除原有的管理员与角色关系记录
     *  2.添加新的管理员与角色关系记录
     *  3.修改管理员信息
     * @param sysUser
     * @return
     */
    @Override
    @Transactional(rollbackFor = Exception.class)
    public Integer modifySysUserInfo(SysUser sysUser) {
        // 获取管理员标识
        Long userId = sysUser.getUserId();
        // 删除原有的管理员与角色关系记录
        sysUserRoleMapper.delete(new LambdaQueryWrapper<SysUserRole>()
                .eq(SysUserRole::getUserId,userId)
        );
        // 添加管理员与角色关系记录
        // 获取管理员的角色id集合
        List<Long> roleIdList = sysUser.getRoleIdList();
        // 判断是否有值
        if (CollectionUtil.isNotEmpty(roleIdList) && roleIdList.size() != 0) {
            // 创建管理员与角色关系的集合
            List<SysUserRole> sysUserRoleList = new ArrayList<>();
            // 循环遍历角色id集合
            roleIdList.forEach(roleId -> {
                // 创建管理员与角色的关系
                SysUserRole sysUserRole = new SysUserRole();
                sysUserRole.setUserId(userId);
                sysUserRole.setRoleId(roleId);
                    /*// 新增管理员与角色的关系
                    注意：不建议在循环中操作数据库，大家尽量需要避免在循环中操作数据库
                    sysUserRoleMapper.insert(sysUserRole);*/
                sysUserRoleList.add(sysUserRole);
            });
            // 批量添加管理员与角色的关系
            sysUserRoleService.saveBatch(sysUserRoleList);
        }
        // 修改管理员信息
        // 获取新密码（如果有值：说明管理员修改了密码，如果没有值：说明原密码不变）
        String newPassword = sysUser.getPassword();
        // 判断是否有值
        if (StringUtils.hasText(newPassword)) {
            // 有值：说明需要修改原密码
            sysUser.setPassword(passwordEncoder.encode(newPassword));
        }
        return sysUserMapper.updateById(sysUser);
    }

    /**
     * 批量/单个删除管理员
     * 1.批量/单个删除管理员与角色的关系记录
     * 2.批量/单个删除管理员
     *
     * @param userIds
     * @return
     */
    @Override
    @Transactional(rollbackFor = Exception.class)
    public Boolean removeSysUserListByUserIds(List<Long> userIds) {
        // 批量/单个删除管理员与角色的关系记录
        sysUserRoleMapper.delete(new LambdaQueryWrapper<SysUserRole>()
                .in(SysUserRole::getUserId,userIds)
        );
        // 批量/单个删除管理员
        return sysUserMapper.deleteBatchIds(userIds)==userIds.size();
    }
}
